<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8"/>
    <title>组件的嵌套</title>
    <script type="text/javascript" src="../../../js/vue.js"></script>
</head>
<body>
<div id="root">
</div>
</body>

<script type="text/javascript">
    Vue.config.productionTip = false

    //定义student组件
    const student = Vue.extend({
        template: `
          <div>
            <h2>学生名称：{{ name }}</h2>
            <h2>学生年龄：{{ age }}</h2>
          </div>
        `,
        data() {
            return {
                name: '曾宇杰',
                age: 22
            }
        }
    })

    //定义school组件
    const school = Vue.extend({
        template: `
          <div>
            <h2>学校名称：{{ name }}</h2>
            <h2>学校地址：{{ address }}</h2>
            <!--                  这里做了嵌套-->
            <student></student>
          </div>
        `,
        components: {
            student
        },
        data() {
            return {
                name: '韩山师范学院',
                address: '广东潮州'
            }
        }
    })

    //定义hello组件
    const hello = Vue.extend({
        template: `
          <h1>{{ msg }}</h1>
        `,
        data() {
            return {
                msg: "欢迎学习Vue教程！"
            }
        }
    })

    //定义app组件
    const app = Vue.extend({
        template: `
          <div>
            <hello></hello>
            <school></school>
          </div>
        `,
        components: {
            school,
            hello
        }
    })

    //创建vm
    new Vue({
        template: `
          <app></app>
        `,
        el: '#root',
        components: {
            app
        }
    })
</script>
</html>

